// pages/login/login.js
import request from '../../utils/request'
Page({

    /**
     * 页面的初始数据
     */
    data: {
        phone: '', // 手机号
        password: '', // 密码
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function (options) {

    },

    // 表单项内容发生改变的回调
    handleInput(event){
        // console.log(event);
        // 变量名赋值要加[] 动态赋值
        // let type = event.currentTarget.id // id传值
        let type = event.currentTarget.dataset.type // data-key = value
        this.setData({
            [type]: event.detail.value
        })
    },

    // 登录回调
    async login() {
        // 收集表单项数据
        let {phone, password} = this.data
        // 前端验证
        if(!phone){
            wx.showToast({
              title: '手机号不能为空',
              icon: 'error'
            })
            return;
        }
        // 定义正则表达式 手机号验证
        let phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/
        if(!phoneReg.test(phone)){
            wx.showToast({
                title: '手机号格式错误',
                icon: 'error'
            })
            return;
        }

        if (!password){
            wx.showToast({
                title: '密码不能为空',
                icon: 'error'
            })
            return;
        }

        // 后端验证
        let result =  await request('/login/cellphone', {phone, password, isLogin: true})
        // console.log(result);
        if (result.code === 200) {
            wx.showToast({
                title: '登录成功'
            })

            // 将用户信息存储到本地
            wx.setStorageSync('userInfo', JSON.stringify(result.profile))

            // 成功后跳转到个人中心
            // 这里跳转不能用switchTab 跳转后没有关闭之前的personal页面 personal不会执行onload方法 获取不到用户的信息
            // 可以在personal页面将获取用户信息的方法放在onshow方法中 但onshow会执行多次 频繁次数会造成性能损耗 onload只执行一次
            // 使用relaunch跳转方法 重新编译
            wx.reLaunch({
                url: '/pages/personal/personal',
            })
        } else if (result.code === 400) {
            wx.showToast({
                title: '手机号错误',
                icon: 'error'
            })
        } else if (result.code === 502) {
            wx.showToast({
                title: '密码错误',
                icon: 'error'
            })
        } else {
            wx.showToast({
                title: '登录失败，请重新登录',
                icon: 'none'
            })
        }

    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function () {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function () {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function () {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function () {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function () {

    }
})